Claims 



We claim: 



1 . Iif a c 'oiiipu lei ' system - comprising a h ostiiLc ommunica tion with a graphics 
processor, a method for the graphics processor to store state data in a buffer residing in 
the graphics processor, the method comprising: y 

receiving and storing N sets of state data to the buffer, where the total length of 
the N sets of state data does not exceed a length of the buffer, and wherein at teast one set 
of the N sets of state data is used to process graphics primitives; and / 

prohibiting an additional set of state data from being stored the buffer when N 
equals a maximum number of allowed states. / 

2. The method of claim 1, wherein the maximum number of allowed states is 
two. / 

3. The method of claim 1 , Mther comprising: 

determining that M sets of sjate data of the N sets of state data are no longer being 
used to process the graphics primitives before writing the additional set of state data to 
the buffer, wherein M < N:/and 

permitting the Additional set of state data to be stored in the buffer when the M 
sets of state data ajfe no longer being used to process the graphics primitives. 

/4. The method of claim 1, wherein the buffer comprises either of a code 
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5. In a computer system comprising a host in communication with a graphics 
processor, a method for the host to update state data in a buffer reading in the graphics 
processor, the method comprising: / 

writing N sets of state data to the buffer, where the total length of the N sets of , 
5 state data does not exceed a length of the buffer, and where aft least one set of the N sets 
of state data is used to process graphics primitives; / 

determining whether a length of an additional set of state data would exceed 
available space in the buffer; and / 

when the length of the additional set of state iata exceeds the available space in 

\\3 J 

rij 10 the buffer, waiting until M sets of state data of the N sets of state data are no longer being 

fri / 
Lll J 

"**J used to process the graphics primitives before writing the additional set of state data to 

the buffer, wherein M < N and each of the M sets of state data would be at least partially 

tx / 

~JX overwritten by the additional set of state data. / 

UJ / 
(3 / 

Lb 15 6. The method of claim 5, wherein the buffer is a ring buffer and the 

available space in the buffer is the difference between the length of the buffer and the 
total length of the N sets of state data. / 

7. The method of claim 5, wherein N is two. 
20 / 

8. The method of /laim 7, wherein waiting further comprises waiting until all 
N sets of state data are no logger being used to process the graphics primitives. 
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9. The method of claim 5, wherein waiting further comprises sending a flush 
command to the graphics processor that causes the graphics processor to refuse the 
additional set of state data until at least one set of the N s/ts of state data is no longer 
being used to process the graphics primitives. 

10. The method of claim 5, wherein the/buffer comprise either of a code 
buffer and constant buffer. 
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11. A computer-readable medium having stored thereon computer-executable 
10 instructions for performing the method of claim/5. 

12. The computer-readable med/um of claim 11, wherein the computer- 
readable instructions are embodied in a graphics processing driver residing in the host. 
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15 13. A graphics processing circuit comprising: 

means for receiving and storing N sets of state data to the buffer, where the total 
length of the N sets of state data does not exceed a length of the buffer, and wherein at 
least one set of the N sets of state d&ta is used to process graphics primitives; and 

means for prohibiting air additional set of state data from being stored in the 
20 buffer when N equals a maximiim number of allowed states. 



14. The apparatus of claim 13, wherein the maximum number of allowed 



states is two. 



20 



15. The apparatus of claim 13, further comprising: / 

means for determining that M sets of state data of the N /ets of state data are no 
longer being used to process the graphics primitives, wherein W< N; and 
5 means for permitting the additional set of state data to be stored in the buffer 

when the M sets of state data are no longer being used to process the graphics primitives. 

16. In a computer systems comprising a/host that provides graphics via a 
display, wherein the host is in communication with a graphics processor to assist in 

10 processing of the graphics, a host-implementecl apparatus for updating state data in a 
buffer residing in the graphics processor, the apparatus comprising: 

means for writing N sets of state data to the buffer, where the total length of the N 
sets of state data does not exceed a lengtii of the buffer, and where at least one set of the 
N sets of state data is used to process g/aphics primitives to be displayed on the display; 

15 means for determining whetMer a length of an additional set of state data would 

exceed available space in the buffer; and 

means, coupled to the means for determining, for waiting until M sets of state data 
of the N sets of state data aj4 no longer being used to process the graphics primitives 
before writing the additional set of state data to the buffer when the length of the 

20 additional set of state dafa exceeds the available space in the buffer, wherein M < N and 
each of the M sets of /state data would be at least partially overwritten by the additional 
set of state data. / 
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17. The apparatus of claim 16, wherein the buffer is a ring buffer and the 
available space in the buffer is the difference between the length of the buffer and the 
total length of the N sets of state data. / 

18. The apparatus of claim 1 6, wherein N is two. 

19. The apparatus of claim 18/wherein the means for waiting waits until all N 
sets of state data are no longer being us/kd to process the graphics primitives. 
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